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ABSTRACT 



A computer system having a graphical system user interface 
for accepting input from a user to create objects in an 
object-oriented computing environment. The system user 
interface generates an XML-compliant template file reflect- 
ing the work- flow defined by input fiom the user. A macro 
list generator displays a representation of the template file 
and prompts for user interface customization options based 
on the template file. The macro list generator generates an 
XML-compliant macro list file reflecting interface customi- 
zation. The system has a custom interface generator to 
present the customized interface to the user, having prompts 
derived from the macro list data. The customized interface 
generator accepts input from the user in response to the 
customized interface prompts and generates an XML- 
compliant application file corresponding to the template file 
as modified to reflect responses of the user to the customized 
interface prompts, 

15 Claims, 7 Drawing Sheets 
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AUTOMATIC GENERATION OF FASTPATH 
APPLICATIONS 

FIELD OF THE INVENTION 5 

The present invention is directed to an improvement in 
computing systems and in particular to a computer system 
that provides improved application construction. 

10 

BACKGROUND OF THE INVENTION 

In computer systems, and in particular in object oriented 
computer systems, programmers and system users define 
applications using standard user interfaces. Users are pro- ^ 
vided with appropriate functions in the user interface to 
permit different applications to be constructed. When mul- 
tiple applications being generated by a user are very similar 
to each other, or share common aspects, the user must 
replicate the work-flow followed in generating a first appli- 20 
cation in later application generation steps. This replication 
by the user is inefficient and also permits errors to be made 
when the user does not successfully replicate the first 
application. 

In prior art systems, scripts or macros can be "recorded" 
and edited. In such systems the keystrokes and/or pointer 
commands of a user are captured in a data file for future use. 
The exact keystrokes may be replayed by invoking the 
appropriate script or macro name. In such systems it is also 30 
possible to edit such files to permit changes to be made to the 
sequence of keystrokes stored in the script or macro file. 

Such systems typically work on a text or GUI -based level. 
In other words, the information which is stored is a repre- 35 
sentation of the input commands which the user generates 
for a particular interface for a particular sequence of com- 
mands or operations. A stored file is "replayed" to recreate 
the steps originally taken by the user, the file to be replayed 
takes the place of input from the keyboard or other input 40 
device of the user. The script or macro file in such a system 
is by definition closely tied to the specific system and the 
specific set of commands or operations which the user 
invokes. AC 

Such systems are useful when a rote series of steps is to 
be retraced a number of times, or when a user is sophisti- 
cated enough to program directly in the script or macro 
language. Such systems do not, however, provide the user 
with a macro or script which is based on an object-oriented 50 
representation, rather than a text based representation, of the 
steps to be replicated. Such systems also do not typically 
provide a powerful mechanism for generalizing or custom- 
izing the macro or script file. 55 

SUMMARY OF THE INVENTION 

According to one aspect of the present invention, there is 
provided an improved system for generating applications. 

According to another aspect of the present invention, 60 
there is provided a computer program product for generating 
user interfaces having a system user interface for accepting 
input from a user, the system user interface generating 
template data reflecting the work-flow defined by input from 65 
the user, a macro list generator for displaying a representa- 
tion of the template data and for accepting input representing 



,589 Bl 

2 

user preferences for interface customization based on the 
template data, the macro list generator generating macro list 
data reflecting the input representing user preferences for 
interface customization, a custom interface generator for 
presenting a customized interface to the user, the customized 
interface comprising prompts derived from the macro list 
data, the customized interface generator accepting input 
from the user in response to the customized interface 
prompts and further comprising an application generator for 
generating application data corresponding to the template 
data as modified to reflect responses of the user to the 
customized interface prompts. 

According to another aspect of the present invention, 
there is provided a computer program product as described 
above in which the template data, the macro list data and the 
application data are in the form of XML-compliant code, the 
accepting input representing user preferences further com- 
prises prompting for each element and attribute defined in 
the XML-compliant code of the template data. 

According to another aspect of the present invention, 
there is provided a computer program product as described 
above further comprising prompts for user preferences for 
customization of the template data comprising a set of 
prompts selected from a master set of prompts comprising 
prompts for interface labels, interface descriptions, attribute 
default values, element default values, input field prefixes, 
input field suffixes, element repeatability, input field 
constraints, help text, interface new page control, and help 
file location. 

According to another aspect of the present invention, 
there is provided a computer system comprising a graphical 
system user interface for accepting input from a user to 
create objects in an object-oriented computing environment, 
the system user interface generating a template file reflecting 
the work-flow defined by input from the user, a macro list 
generator for displaying a representation derived from the 
template file and for accepting input representing user 
preferences for interface customization based on the tem- 
plate file, the macro list generator generating a macro list file 
reflecting the input representing user preferences for inter- 
face customization, a custom interface generator for pre- 
senting a customized interface to the user, the customized 
interface comprising prompts derived from the macro list 
data, the customized interface generator accepting input 
from the user in response to the customized interface 
prompts and further comprising an application generator for 
generating an application file corresponding to the template 
file as modified to reflect responses of the user to the 
customized interface prompts. 

According to another aspect of the present invention, 
there is provided a method for generating fastpath applica- 
tions comprising the steps of: 

1. accepting input from a user; 

2. generating template data reflecting the work- flow 
defined by input from the user; 

3. displaying a representation of the template data; 

4. accepting input representing user preferences for inter- 
face customization based on the template data; 

5. generating macro list data reflecting the input repre- 
senting user preferences for interface customization; 
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6. presenting a customized interface to the user, the According to another aspect of the present invention, 
customized interface comprising prompts derived from there is provided a computer program product for use with 
the macro list data; an object-oriented computer system, the computer program 

7. accepting input from the user in response to the duct comprising) a computer usa ble medium having 
customized interface prompts; and 5 , ... , . < • _, - 

, < • * computer readable program code embodied in the medium 

8. generating application data corresponding to the tern- c . . .. 

plate data as modified to reflect responses of the user to for aut0 ™tic application generation, the computer program 
the customized interface prompts. product comprising computer readable program code for 
According to another aspect of the present invention, causing a computer to accept input from a user to create 
there is provided a method for generating fastpath applica- 10 objects in an object-oriented computing environment, cona- 
tions comprising the steps of: puter readable program code for causing a computer to 

1. accepting input from a user to create objects in an generate a template file reflecting the work-flow defined by 
object-oriented computing environment; input from the user, computer readable program code for 

2. generating a template file reflecting the work-flow causing a computer to display a representation derived from 
defined by input from the user; 15 me temp iate file, computer readable program code for caus- 

3. displaying a representation derived from the template mg a comp uter to accept input representing user preferences 

for interface customization based on the template file, com- 

4. accepting input representing user preferences for inter- readable m code for causi a t0 
face customization based on the template file; ^ a ^ ^ fik refle ^ nli 

5. generating a macro list file reflecting the input repre- iU e c . t c . 4 , 
6 . & _ c • * c . ■ *■ user preferences for interface customization, computer read- 
senting user preferences for interface customization; , , , „ . r 

t - , . 4 _c ... ^ able program code for causing a computer to present a 

6. presenting a customized interface to the user, the r . 0 . . „ , L * . j ■ * 
customized interface comprising prompts derived from customized interface to the user, the customized interface 
the macro list data, the customized interface generator comprising prompts derived from the macro list data, and 
accepting input from the user in response to the cus- 25 accepting input from the use in response to the customized 
tomized interface prompts; and interface prompts and computer readable program code for 

7. generating a application file corresponding to the causing a computer to generate an application file corre- 
template file as modified to reflect responses of the user sponding to the template file as modified to reflect responses 
to the customized interface prompts. 3Q of the user to the customized interface prompts. 

According to another aspect of the present invention, Advantages of the present invention include the ability to 

there is provided an article of manufacture including a define a template which is customizable to generate appli- 

computer usable medium having computer readable pro- cations without requiring users to retrace all steps in the 

gram code embodied therein, the computer readable pro- application-generation path. The natural work- flow of the 

gram code in the article of manufacture including computer 35 user is captured by the template file and this work- flow 

readable program code for causing a computer to carry out representation is then used to permit other applications to be 

the steps in the methods set out above. quickly defined by the user. The user may effectively create 

According to another aspect of the present invention, customized user interfaces based on the template file to 
there is provided a computer program product for use with permit the creation of modified applications based on the 
an object-oriented computer system, the computer program 40 template file, 
product including a computer usable medium having com- 
puter readable program code embodied in the medium for BRIEF DESCRIPTION OF THE DRAWINGS 
automatic application generation, the computer program ^ preferred cmbodimcnt of the iavea ti OD is sh own in 
product including: 45 the drawings, wherein: 

computer readable program code for causing a computer t a ^ m sh ^ architecture of the 

to accept input from a user, computer readable program ^ & 

code for causing a computer to generate template data Purred embodiment. 

reflecting the work-flow defined by input from the user, FIGS. 2-5 are screen captures representing interfaces in 

computer readable program code for causing a com- 50 accordance with the preferred embodiment, 

puter to display a representation of the template data, FIG. 6 is a block diagram showing the architecture of the 

computer readable program code for causing a com- fcrred em5odiment &om a user orie nted perspective, 
puter to accept input representing user preferences for 

interface customization based on the template data, Ia the drawings, the preferred embodiment of the inven- 

computer readable program code for causing a com- 55 tion is illustrated by way of example. It is to be expressly 

puter to generate macro list data reflect the input understood that the description and drawings are only for the 

representing user preferences for interface purpose of illustration and as an aid to understanding, and 

customization, computer readable program code for are not intended as a definition of the limits of the invention, 
causing a computer to present a customized interface to 

the user, the customized interface comprising prompts 60 DESCRIPTION OF THE PREFERRED 

derived from the macro list data, computer readable EMBODIMENT 

program code for causing a computer to accept input Reflec(i FI0 , , h6re ^ shown ;„ a b , ock di ^ 

from the user in response to the customized interface , . r L c , , .. 

, . j i_ 1 j * architecture of the preferred embodiment, 

prompts and computer readable program code for caus- r 

ing a computer to generate application data correspond- 65 Tb e preferred embodiment is described with reference to 

ing to the template data as modified to reflect responses the IBM Component Broker™ system. However, it will be 

of the user to the customized interface prompts. understood by those skilled in the art that the invention may 
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be implemented with respect to other environments which 
support application creation, preferably in which an XML 
(or other textual ly -based) description of the application 
creation is supportable. 

FIG. 1 shows a system user interface 10. This interface 
provides the functionality for a user to generate a specific 
application in a computer system. In the object-oriented 
model of the preferred embodiment, system user interface 10 
permits the user to construct a set of objects. In use system 
user interface 10 may be used to construct objects and in this 
sense different applications may be generated directly by 
using the system user interface 10. In the system of the 
preferred embodiment an application is represented by an 
XML file, as described below. The XML file is used by other 
system components to implement an application. 

In the system of FIG. 1, when system user interface 10 is 
used to generate an application, the system also creates an 
XML file which reflects the work-flow of the user in 
generating the application. In FIG. 1, the user input 12 is 
shown reflecting user input to define a template application. 
The system user interface 10 generates XML template file 
14. XML template file 14 is shown in FIG. 1 with an 
associated DTD file 15. The DTD file 15 is not required in 
the preferred embodiment but is advantageous in permitting 
XML code to be defined which is able to concisely describe 
the user interface customization, as referred to below. XML 
template file 14 may represent, for example, objects created 
by a user for use in a system having an object request broker 
architecture. 

XML template file 14 is used in such a system as a basis 
for the object request broker system to create corresponding 
objects for use in the system. 

A further component of the system shown in FIG. 1 is 
macro list generator 16, which prompts for and accepts user 
input 18. Macro list generator 16 creates macro list XML file 
20 in response to user input 18. 

FIG. 1 also shows custom XML generator 22 which 
permits users to generate applications by prompting for and 
accepting user inputs, shown in FIG. 1 as user inputs 24, 26, 
28 and, by way of user sessions 30, 32, 34, based on macro 
list XML file 20, generating applications 36, 38, 40, respec- 
tively. 

System user interface 10 may potentially be any user 
interface. In the preferred embodiment, system user inter- 
face 10 is a graphical, menu-based interface which permits 
the construction of object-oriented business applications. An 
example of the interface is given in FIG. 2 which represents 
system user interface 10 as represented to the user in an 
example of application creation. As can be seen from FIG. 
2, system user interface 10 has task and object pane 60, 
inheritance pane 62, and methods pane 64. The objects being 
created by the user are represented in those three panes. The 
work-flow of the user in utilizing system user interface 10 is 
reflected in the graphical structure shown in pane 60. In the 
preferred embodiment, the graphical structure in pane 60 
corresponds to an XML-compliant file of tagged text. In the 
preferred embodiment, an XML file of this type is shown as 
XML template file 14 in FIG. 1. This user interface provides 
an XML representation of the user's work-flow in defining 
objects in the object-oriented system. It is this correspon- 
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dence which is utilized as described below to permit the 
customization of the user interface to permit automatic 
generation of fastpath applications. 

The elements in the XML-compliant data may be defined 
in an XML data type definition ("DTD") file which is 
specific to the system. The data type definition file is defined 
itself in a manner consistent with the applications which the 
system is designed to create. This permits the work- flow of 

10 a user in creating objects in an application to be represented 
directly and clearly by XML data. 

An XML representation of the user work-flow is shown in 
FIG. 1 where a user uses system user interface 10 to create 

15 a template application represented by user input 12 in FIG. 
1. The template application may be simple or complex but 
it is advantageous for the user to include details which arc 
to be replicated in other applications to be created by the 
user or other users. Similarly, it is advantageous if the user 

20 restricts the template application to only contain objects 
which are likely to be used in other applications. 

System user interface 10 generates XML template file 14. 
As set out above, XML template file 14 contains elements 

25 which correspond to the objects in the application which the 
user has defined. The work-flow of the user is represented in 
XML template file 14. 

Once the XML template file 14 has been created, the user 
may run macro list generator 16 to create macro list XML 

30 file 20. Macro list generator 16 uses XML template file 14 
as input to present the user with options to customize what 
is to be presented to users in building subsequent applica- 
tions. In the preferred embodiment, macro list generator 16 

35 presents the user with a graphical representation of macro 
list XML file 20. The user may select those elements of the 
XML template file 14 which the user wishes to permit future 
applications to have customized. 

An example of what is presented to the user by macro list 

40 generator 16 is shown in FIG. 3, where in pane 70 the 
representation of an XML template file 14 for an example 
template is shown. 
The example of FIG. 3 shows a set of objects created by 

45 the user originally in the system user interface. For the 
purposes of the example, the objects are defined as 
"elideElements". The details of the objects which are created 
by the system user interface will vary depending on the 
system user interface under consideration. For a system user 

50 interface used to build a component-based object oriented 
system, objects and tasks defined by the user may be shown 
in pane 70. In the example of FIG. 3 a simple object-creation 
example is provided. In the preferred embodiment the 

55 details of the objects defined do not determine how the 
system works, what is required is that the system user 
interface 10 generate an XML file for the objects which is 
persistent and which represents user interface state data. 
In the example of FIG. 3, a "Name" attribute 72 is shown 

60 highlighted. Box 74 in FIG. 3 is displayed by macro list 
generator 16 to permit the user to define the name attribute 
as being customizable by future applications to be built on 
the template of the example. Dropdown box 76 permits the 

65 user to define the macro to be "editable" which permits the 
user to define prompts for display when applications are to 
be defined in subsequent use of the system with the fastpath 
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application of the custom XML generator 22. Where drop Note that in the example of FIG. 3, pane 70 displays the 
down box 76 is set to "hidden" instead of "editable", XML in a particular formal as defined by macro list gen- 
applications created based on the template are given ele- erator 16 in which the values contained in the template XML 
ments and attributes which are duplicates of the elements ("Uuid" for example) are not displayed, 
and attributes in the template. 5 A corresponding XML description relating to the objects 

In box 74 of FIG. 3 the user is prompted to define a label 1x1 mG 3 generated by macro generator 16 is as follows: 

which will be presented to the user in a customized interface <?xml version="1.0" standalone«"no"?><!DOCTYPE 

for defining a new application based on the template. In the macros SYSTEM 

example of FIG. 3, the user has entered "the object name" 10 U 'i^^^ T ^ x ^ maCr0S> <tetDplale href " 

as the text which will label the prompt. A default value of * " ' ™ > x x it XXT x „ 
«a n f u »* u i u ■ u « a <macro path="root( )xhild(l,elide).attr(Name)" 
"A_Default_Value is shown as also having been entered name="the object name- 
in box 74 of FIG. 3. Prefix and suffix strings may also be d efault~"A_Default_Value" showType-" Editable" 
specified by the user. The prefix and suffix definition is of constraint="0"/> 
use where the value for the default string is a derived value 15 </macros> 

(indicated by the derived value check box in box 74), In such macr0 XML code represents the contents of macro 

a case, the value may be defined to be derived from another H st XML file 20 as shown in FIG. 1. The code is generated 

attribute or element with a user defined prefix or suffix by macro list generator 16 for the input as shown in FIG. 3, 

catenated with the derived value string. 20 based on the template XML shown above. In the example of 

Macro list generator 16 also provides that the data to be FIG. 3, as illustrated by the macro XML code above, a DTD 

accepted be constrained in a user-selectable manner. In the file (corresponding to DTD file 15 in FIG. 1) is used to 

example of FIG. 3, the constraint is selected to be define the "macro" construct in the macro XML code. In the 

"NoSpace", requiring the user to enter names which do not ^ above example, the DTD file is identified as ".. /dtd/ 

contain the space character. Box 74 also contains a location macro.dtd". The DTD file for the preferred embodiment 

where text for fly-over help (hover help) may be entered. includes definitions of XML constructs which are specific to 

FIG. 3 also contains box 78 which has check off box 80, the macro list generator tasks. For example the DTD file 

to be checked where the prompting for the highlighted contains the following: 

element (in the example of FIG. 3, "elide" 72), is to appear 30 <|ATTLIST macro 

on a new page for the user. If check off box 80 is checked, [■•■]■ 

the user may enter a title for the new page, a description to showType (Hidden|Editable|Readonly) "Editable" 

appear on the new page, and a help URL for the new page, [ • • • ] 

each in the appropriate space in box 78. „ «, , . , , , , «• c<u ^™ 

rr r r 35 The ehpses above indicate redacted portions of the DTD 

Box 78 also contains check off box 82 which permits the definition. This definition, for example, permits the data 

user to define whether an element is repeatable. If the entered by the user (user input 18) in running macro list 

element is defined as repeatable, when the application is generator 16 to be directly reflected in a "macro" statement 

defined (as described below) the user will be able to replicate ^ macr0 Ust filc 2 o by a showType value correspond- 

the element in the application. 40 ing t0 the user > s As will be apparent, different DTD 

Based on the user selection of elements and attributes files will be desirable for different system user interfaces, 

presented by macro list generator 16, macro list XML file 20 The "template" statement in the above macro XML code 

is created. Macro list XML file 20 reflects modifications for identifies the location of the XML template file to which the 

XML template file 14, representing the customizable ele- 45 macro file will refer. In this case, the "H:\test\input.xml" 

ments as defined by the user, using macro list generator 16. location refers to the file containing the template XML code 

The XML description for the objects in pane 70 of FIG. shown above. 

3 is as follows: The "macro" statement in the above macro XML code 

<?xml version-"1.0" standalone -"yes"?x!DOCTYPE 50 contains the "path" component which identifies a location in 

elideElements> me template XML file. In the example above, the path points 

21 elideElements> <eiide Name="Uuid" Visible- to the first "name" attribute in the template XML code. The 

"false"></elide> <elide Name«"foo" Icon="images/ macro XML code above includes "the object name" string 

domodule.gif *> </elide> which reflects the entry made by the user as shown in FIG. 

</elideElements> 55 3 for the label for attribute name. The user provided default 

This template XML code corresponds to the contents of is also reflected in the macro XML code ("A_Defaull__ 

XML template file 14 shown in FIG. 1. The template XML Value"). The "showType" is set in the macro XML code 

in the example of FIG. 3 is sufficient to represent the work based on the user's input as shown in drop down box 76 in 

flow of the user in defining the objects to be created by the FIG. 3. Similarly the "constraint" information is shown in 

system. Although in the context of the preferred 60 the macro XML code above, reflecting the user entry in 

embodiment, the template XML is used to permit custom i- response to the prompt from the macro list generator, 

zation of the user interface for fastpath application As will be appreciated, the macro list XML file 20 will 

generation, in the context of the system itself, the XML differ for different system. It is required that macro list 

generated by the system user interface is used to pass the 65 generator 16 creates a file which is able to be parsed by 

user input to the system for processing (see the description custom XML generator 22. In fact, the output of macro list 

of FIG. 6, below). generator 16 may have any format which can be read by 
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custom XML generator 22. In the preferred embodiment, an <elide Name="foo" Icon="images/domodule.gif' /> 

XML file is used and DTD file 15 is used to define XML </elideElements> 

code wbich permits the output of macro list generator 16 to As can be seen, the application as originally defined by 

be tailored to the function of passing user information $ the user and reflected in the XML template code listed 

relating to XML template file 14 to custom XML generator above, has been replicated but with the customization that 

22. the first Name attribute has been given the value "User_ 

When a macro list XML file 20 has been defined by the provided_name", instead of the value "Uuid" which it had 

user, it is then possible for the user to run custom XML in the template XML code. 

generator 22 to define applications. Custom XML generator 10 In the example of FIG. 1, user input 24 to custom XML 

22 effectively displays customized user interfaces by dis- generator 22 is used by the custom XML generator, in 

playing prompts to the user based on macro list XML file 20. addition to the information contained in the macro list file 

In cases where there are no editable macros defined for a set 20, to generate application XML 36 which is based on the 

of objects, the system will replicate the original template i 5 template application of user input 12, but which has been 

application as defined in XML template file 14, with no customized by the user in accordance with the prompts 

customized aspects. defined by user input to macro list generator 16. Other 

Where, as in the example of FIG. 3, the user does define application XMLs 38, 40 are similarly created by users 

customizable aspects to the application generation, pages are defining the customizable elements as originally selected by 

displayed by the macro list generator 16 which permit 20 user 0 f t h e macro list generator 16. 

customization of the application being generated. An As can be seen by the above description, in the system of 

example of such a page is found in FIG. 4. In the preferred mc pre f 6rre d embodiment, an application is defined itself in 

embodiment, custom XML generator 22 uses the value of XML code. This is shown in FIG. 6, which represents the 

"showType" in macro list XML file 20 to determine whether 25 architecture of tne system ^ seen from tne user p erspecl i vc . 

a particular element or attribute will be presented to the user. nG fi has ^ . m m m User . u0 fof 

If the showType is "editable" then the element or attribute ffl ^ m fa XML m Sys , em 

will be presented with an entry field which the user can use ne[)ls m then ^ ^ L m , 0 drive syst6m opera . 

to enter a value. A default value, if defined, will be dis- ^ fa nG fi usef m m usef imerface u6 

played. Where the showType is "readonly" a default value or » ^ ^ ug ^ ^ tQ ^ mpu , u sys , em ^ 

a derived value will be displayed without the opportunity for m(erface 10 &Q(J XML , emplate fik M> sfaown in FIG h 

the user to modify the value. When the showType is "hid- XML 118 represents the application defined by the user by 

den" nothing is displayed for the user. u$er . no tQ sys , em ^ imerface u6 

FIG. 4 shows the screen displayed for a user by custom 3J Iq addition> ^ m ^ used , o dfive ^ customized user 

XMLgenerator22 based on the user inputs as shown in FIG. . Dterfacc deflnition m , n terms of FlG j customized US6r 

3, where the name attribute is not repeatable. FIG. 4 shows deflnilioQ 122 re p reS ents macro list generator 16 

the label as being "the object name" with entry field 89. and macro M ^ fi , e 2Q Uger input m u used tQ cfeate 

Hover help 90 is shown defined as "Enter the name of the wha( ^ seen by me ^ a custom system ^ ut6rface m 

thing you are creating" as shown in FIG. 3. The user in FIG. 40 ^ fa ^ fey ^ ^ ^ ^ custQm sys(em ^ jmerface 

4 is able to give a value to "the object name". The default fa ted by , he custom XML generator m nG L User 

value "A_Default_Value" as defined in FIG. 3 is presented . m b iM (u fa shown in mGS 4 5) tQ generate 

to the user in entry field 89. In this way, what are defined by a fas fa licatioil; represente d in FIG. 6 as XML 126. 

the user in FIG. 3 to be the customizable aspects of the +J XML m represents an application in ^ same manner as 

application arc presented to the user to permit fastpath does ^ ug Jhe fastpath fof generaling ^ U6 - a by 

application building. custom system user mlerface 124 wn i c h uses XML 118 as a 

FIG. 5 shows a similar screen presented to the user but in , ale an(J jts customization „ defined by ^ input 

FIG. S the object being defined by the user is repeatable. In ^ 

this case, the user is presented with a tree-structured graphi- 50 Iq ^ way a fa ^ quick , y defin£ applications 

cal representation of the objects being created by the user in which afe based on ^ user . defined temp late, but which are 

box 96 The label and entry field 98 have the same function customizable ^ ft manner defined by tne ^ In tne pre . 

as the label and entry field 89 shown in FIG. 4. In FIG. 5 {em<} 6mbodimenl> diff6rent customization options may be 

however, button 100 is provided to permit the user to add ^ deflned fof ^ game temp , ate> aUowing different po(ential 

other objects to what is being developed. The defined objects ^ tQ ^ yejsioa& Qf me template 

are shown in the tree of box 96 and new objects may be ^ template fik u ^ fae ^ as macro m 

defined using entry field 98. XML fl , e ^ where ^ subsequent app i icatioris are 

In the example shown in FIG. 4, if the user replaces ^ of ^ lempla[e application However, in most cases it 

"A_Default_Value" in entry field 89 with "User_ 6 o ^ expected thal ^ ^ benefit from the ability to use the 

Provided_Name", the XML file which is generated by the macro ^ approach desc[ibed abQve 

custom XML generator will be as follows: Although a preferred embodiment of the present invention 

<?xml version="1.0" standalone="yes"?> has been descnDe d here in detail, it will be appreciated by 

<!DOCTYPE elideElements> 65 those skilled in the art, that variations may be made thereto, 

<elideElements> without departing from the spirit of the invention or the 

<elide Name-"User_provided_name" Visible-"false'7> scope of the appended claims. 
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What is claimed is: 

1. A computer program product for generating user inter- 
faces comprising 

a system user interface that accepts input from a user, the 
system user interface generating template data reflect- 
ing the work- flow defined by input from the user, 

a macro list generator that displays a representation of the 
template data and for accepting input representing user 
preferences for interface customization based on the 
template data, the macro list generator generating 
macro list data reflecting the input representing user 
preferences for interface customization; and 

a custom interface generator that presents a customized 
interface to the user, the customized interface compris- 
ing prompts derived from the macro list data, the 
customized interface generator accepting input from 
the user in response to the customized interface 
prompts and further comprising an application genera- 
tor for generating application data corresponding to the 
template data as modified to reflect responses of the 
user to the customized interface prompts. 

2. The computer program product of claim 1 in which the 
template data and the application data each comprises XML- 
compliant code. 

3. The computer program product of claims 1 or 2 in 
which the macro list data comprises XML-compliant code. 

4. The computer program product of claim 3 further 
comprising a data type definition file associated with the 
XML-compliant code of the template data, the application 
data and the macro list data. 

5. The computer program product of claim 4 further 
comprising prompts for user preferences for customization 
of the template data comprising a set of selected prompts 
selected for a master set of prompts comprising prompts for 
interface labels, interface descriptions, attribute default 
values, element default values, input field prefixes, input 
field suffixes, element repeatability, input field constraints, 
help text, interface new page control, and help file location 
and in which the set of selected prompts is defined by the 
contents of the data type definition. 

6. The computer program product of claim 2 in which the 
accepting input representing user preferences further com- 
prises prompting for each element and attribute defined in 
the XML-compliant code of the template data. 

7. The computer program product of claim 1 in which the 
system user interface comprises a graphical user interface 
for creation of objects in an object-oriented programming 
environment. 

8. The computer program product of claim 1 further 
comprising prompts for user preferences for customization 
of the template data comprising a set of prompts selected 
from a master set of prompts comprising prompts for 
interface labels, interface descriptions, attribute default 
values, element default values, input field prefixes, input 
field suffixes, element repeatability, input field constraints, 
help text, interface new page control, and help file location. 

9. A computer system comprising 

a graphical system user interface that accepts input from 
a user to create objects in an object-oriented computing 
environment, the system user interface generating a 
template file reflecting the work-flow defined by input 
from the user; 

a macro list generator that displays a representation 
derived from the template file and for accepting input 
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representing user preferences for interface customiza- 
tion based on the template file, the macro list generator 
generating a macro list file reflecting the input repre- 
senting user preferences for interface customization; 
and 

a custom interface generator that presents a customized 
interface to the user, the customized interface compris- 
ing prompts derived from the macro list data, the 
customized interface generator accepting input from 
the user in response to the customized interface 
prompts and further comprising an application genera- 
tor for generating an application file corresponding to 
the template file as modified to reflect responses of the 
user to the customized interface prompts. 

10. A method for generating fastpath applications com- 
prising the steps of: 

accepting input from a user; 

generating template data reflecting the work-flow defined 
by input from the user; 

displaying a representation of the template data; 

accepting input representing user preferences for interface 
customization based on the template data; 

generating macro list data reflecting the input representing 
user preferences for interface customization; 

presenting a customized interface to the user, the custom- 
ized interface comprising prompts derived from the 
macro list data; 

accepting input from the user in response to the custom- 
ized interface prompts; and 

generating application data corresponding to the template 
data as modified to reflect responses of the user to the 
customized interface prompts. 

11. An article of manufacture comprising a computer 
usable medium having computer readable program code 
embodied therein, the computer readable program code in 
said article of manufacture comprising computer readable 
program code for causing a computer to carry out the steps 
in the method of claim 10. 

12. A method for generating fastpath applications com- 
prising the steps of: 

accepting input from a user to create objects in an 
object-oriented computing environment; 

generating a template file reflecting the work-flow defined 
by input from the user; 

displaying a representation derived from the template file; 

accepting input representing user preferences for interface 
customization based on the template file; 

generating a macro list file reflecting the input represent- 
ing user preferences for interface customization; 

presenting a customized interface to the user, the custom- 
ized interface comprising prompts derived from the 
macro list data, the customized interface generator 
accepting input from the user in response to the cus- 
tomized interface prompts; and 

generating an application file corresponding to the tem- 
plate file as modified to reflect responses of the user to 
the customized interface prompts. 

13. An article of manufacture comprising a computer 
usable medium having computer readable program code 
embodied therein, the computer readable program code in 
said article of manufacture comprising computer readable 
program code for causing a computer to carry out the steps 
in the method of claim 12. 



05/18/2004, EAST Version: 1.4.1 



US 6,5' 

13 

14. A computer program product for use with an object- 
oriented computer system, said computer program product 
comprising: a computer usable medium having computer 
readable program code embodied in said medium for auto- 
matic application generation, said computer program prod- 
uct comprising: 

computer readable program code that causes a computer 
to accept input from a user; 

computer readable program code that causes a computer 
to generate template data reflecting the work-flow 
defined by input from the user; 

computer readable program code that causes a computer 
to display a representation of the template data; 

computer readable program code that causes a computer 
to accept input representing user preferences for inter- 
face customization based on the template data; 

computer readable program code that causes a computer 
to generate macro list data reflect the input representing 
user preferences for interface customization; 

computer readable program code that causes a computer 
to present a customized interface to the user, the 
customized interface comprising prompts derived from 
the macro list data; 

computer readable program code that causes a computer 
to accept input from the user in response to the cus- 
tomized interface prompts; and 

computer readable program code that causes a computer 
to generate application data corresponding to the tem- 
plate data as modified to reflect responses of the user to 
the customized interface prompts. 

15. A computer program product for use with an object- 
oriented computer system, said computer program product 
comprising: 
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a computer usable medium having computer readable 
program code embodied in said medium for automatic 
application generation, said computer program product 
comprising: 

5 computer readable program code that causes a com- 
puter to accept input from a user to create objects in 
an object-oriented computing environment; 
computer readable program code that causes a com- 
10 puter to generate a template file reflecting the work- 

flow defined by input from the user; 
computer readable program code that causes a com- 
puter to display a representation derived from the 
template file; 

15 computer readable program code that causes a com- 
puter to accept input representing user preferences 
for interface customization based on the template 
file; 

20 computer readable program code that causes a com- 
puter to generate a macro list file reflecting the input 
representing user preferences for interface customi- 
zation; 

computer readable program code that causes a com- 
25 puter to present a customized interface to the user, 

the customized interface comprising prompts 
derived from the macro list data, and accepting input 
from the user in response to the customized interface 
prompts; and 

30 computer readable program code that causes a com- 
puter to generate an application file corresponding to 
the template file as modified to reflect responses of 
the user to the customized interface prompts. 

* * * * * 
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